**General Description** 

## 1.4 Pin Assignments

The MC68HC908QT4A, MC68H908QT2A, and MC68HC998QT1A are available in 8-pin packages. The MC68HC908QY4A, MC68HC908QY2A, and MC68HC908QY1A are available in 16-pin packages. Figure 1-2 shows the pin assignment for these packages.



Figure 1-2. MCU Pin Assignments

MC68HC908QYA/QTA Family Data Sheet, Rev. 3

#### Memory



Figure 2-1. Memory Map

# **Chapter 5 Configuration Register (CONFIG)**

## 5.1 Introduction

This section describes the configuration registers (CONFIG1 and CONFIG2). The configuration registers enable or disable the following options:

- Stop mode recovery time (32 × BUSCLKX4 cycles or 4096 × BUSCLKX4 cycles)
- STOP instruction
- Computer operating properly module (COP)
- COP reset period (COPRS): 8176 × BUSCLKX4 or 262,128 × BUSCLKX4
- Low-voltage inhibit (LVI) enable and trip voltage selection
- Auto wakeup timeout period
- Allow clock source to remain enabled in STOP
- Enable IRQ pin
- Disable IRQ pin pullup device
- Enable RST pin

## 5.2 Functional Description

The configuration registers are used in the initialization of various options. The configuration registers can be written once after each reset. Most of the configuration register bits are cleared during reset. Since the various options affect the operation of the microcontroller unit (MCU) it is recommended that this register be written immediately after reset. The configuration registers are located at \$001E and \$001F, and may be read at anytime.

### NOTE

The CONFIG registers are one-time writable by the user after each reset. Upon a reset, the CONFIG registers default to predetermined settings as shown in Figure 5-1 and Figure 5-2.



Figure 5-1. Configuration Register 2 (CONFIG2)

#### **Configuration Register (CONFIG)**

## IRQPUD — IRQ Pin Pullup Control Bit

- 1 = Internal pullup is disconnected
- $0 = Internal pullup is connected between <math>\overline{IRQ}$  pin and  $V_{DD}$

## IRQEN — IRQ Pin Function Selection Bit

- 1 = Interrupt request function active in pin
- 0 = Interrupt request function inactive in pin

## OSCENINSTOP— Oscillator Enable in Stop Mode Bit

OSCENINSTOP, when set, will allow the clock source to continue to generate clocks in stop mode. This function can be used to keep the auto-wakeup running while the rest of the microcontroller stops. When clear, the clock source is disabled when the microcontroller enters stop mode.

- 1 = Oscillator enabled to operate during stop mode
- 0 = Oscillator disabled during stop mode

#### RSTEN — RST Pin Function Selection

- 1 = Reset function active in pin
- 0 = Reset function inactive in pin

#### NOTE

The RSTEN bit is cleared by a power-on reset (POR) only. Other resets will leave this bit unaffected.



Figure 5-2. Configuration Register 1 (CONFIG1)

## COPRS (Out of Stop Mode) — COP Reset Period Selection Bit

- 1 = COP reset short cycle = 8176 × BUSCLKX4
- 0 = COP reset long cycle = 262,128 × BUSCLKX4

## COPRS (In Stop Mode) — Auto Wakeup Period Selection Bit, depends on OSCSTOPEN in CONFIG2 and external clock source

- $1 = \text{Auto wakeup short cycle} = 512 \times (INTRCOSC or BUSCLKX2)$
- 0 = Auto wakeup long cycle = 16,384 × (INTRCOSC or BUSCLKX2)

## LVISTOP — LVI Enable in Stop Mode Bit

When the LVIPWRD bit is clear, setting the LVISTOP bit enables the LVI to operate during stop mode. Reset clears LVISTOP.

- 1 = LVI enabled during stop mode
- 0 = LVI disabled during stop mode

#### LVIRSTD — LVI Reset Disable Bit

LVIRSTD disables the reset signal from the LVI module.

- 1 = LVI module resets disabled
- 0 = LVI module resets enabled

59

## LVIPWRD — LVI Power Disable Bit

LVIPWRD disables the LVI module.

- 1 = LVI module power disabled
- 0 = LVI module power enabled

## LVITRIP — LVI Trip Point Selection Bit

LVITRIP selects the voltage operating mode of the LVI module. The voltage mode selected for the LVI should match the operating  $V_{DD}$  for the LVI's voltage trip points for each of the modes.

- 1 = LVI operates for a 5-V protection
- 0 = LVI operates for a 3-V protection

#### NOTE

The LVITRIP bit is cleared by a power-on reset (POR) only. Other resets will leave this bit unaffected.

## SSREC — Short Stop Recovery Bit

SSREC enables the CPU to exit stop mode with a delay of 32 BUSCLKX4 cycles instead of a 4096 BUSCLKX4 cycle delay.

- 1 = Stop mode recovery after 32 BUSCLKX4 cycles
- 0 = Stop mode recovery after 4096 BUSCLKX4 cycles

#### **NOTE**

Exiting stop mode by an LVI reset will result in the long stop recovery.

When using the LVI during normal operation but disabling during stop mode, the LVI will have an enable time of  $t_{\text{EN}}$ . The system stabilization time for power-on reset and long stop recovery (both 4096 BUSCLKX4 cycles) gives a delay longer than the LVI enable time for these startup scenarios. There is no period where the MCU is not protected from a low-power condition. However, when using the short stop recovery configuration option, the 32 BUSCLKX4 delay must be greater than the LVI's turn on time to avoid a period in startup where the LVI is not protecting the MCU.

## STOP — STOP Instruction Enable Bit

STOP enables the STOP instruction.

- 1 = STOP instruction enabled
- 0 = STOP instruction treated as illegal opcode

#### COPD — COP Disable Bit

COPD disables the COP module.

- 1 = COP module disabled
- 0 = COP module enabled

Central Processor Unit (CPU)

## 7.7 Instruction Set Summary

Table 7-1 provides a summary of the M68HC08 instruction set.

Table 7-1. Instruction Set Summary (Sheet 1 of 6)

| Source                                                                                         | Operation                                            | Description                                              |   |            | Effect on CCR |          |          |           | ress                                                                                         | Opcode                                           | Operand                                         | les                             |
|------------------------------------------------------------------------------------------------|------------------------------------------------------|----------------------------------------------------------|---|------------|---------------|----------|----------|-----------|----------------------------------------------------------------------------------------------|--------------------------------------------------|-------------------------------------------------|---------------------------------|
| Form                                                                                           | operation.                                           | 2000                                                     | ٧ | Н          | I             | N        | Z        | С         | Addres                                                                                       | Opc                                              | Ope                                             | Cycles                          |
| ADC #opr<br>ADC opr<br>ADC opr<br>ADC opr,X<br>ADC opr,X<br>ADC,X<br>ADC opr,SP<br>ADC opr,SP  | Add with Carry                                       | $A \leftarrow (A) + (M) + (C)$                           | ‡ | ‡          | _             | 1        | <b>‡</b> | ‡         | IMM DIR EXT IX2 IX1 IX SP1 SP2                                                               | A9<br>B9<br>C9<br>D9<br>E9<br>F9<br>9EE9<br>9ED9 | ii<br>dd<br>hh II<br>ee ff<br>ff<br>ff<br>ee ff | 2 3 4 4 3 2 4 5                 |
| ADD #opr<br>ADD opr<br>ADD opr<br>ADD opr,X<br>ADD opr,X<br>ADD ,X<br>ADD opr,SP<br>ADD opr,SP | Add without Carry                                    | A ← (A) + (M)                                            | 1 | <b>‡</b>   | _             | ‡        | ‡        | 1         | IMM<br>DIR<br>EXT<br>IX2<br>IX1<br>IX<br>SP1<br>SP2                                          | AB<br>BB<br>CB<br>DB<br>EB<br>FB<br>9EEB<br>9EDB |                                                 | 2 3 4 4 3 2 4 5                 |
| AIS #opr                                                                                       | Add Immediate Value (Signed) to SP                   | $SP \leftarrow (SP) + (16   ^{\vee}  M)$                 | _ | -          | _             | _        | _        | _         | IMM                                                                                          | A7                                               | ii                                              | 2                               |
| AIX #opr                                                                                       | Add Immediate Value (Signed) to H:X                  | H:X ← (H:X) + (16 « M)                                   | _ | -          | _             | _        | _        | _         | IMM                                                                                          | AF                                               | ii                                              | 2                               |
| AND #opr<br>AND opr<br>AND opr<br>AND opr,X<br>AND opr,X<br>AND,X<br>AND opr,SP<br>AND opr,SP  | Logical AND                                          | A ← (A) & (M)                                            | 0 | -          | _             | <b>‡</b> | ‡        | _         | IMM<br>DIR<br>EXT<br>IX2<br>IX1<br>IX<br>SP1<br>SP2                                          | A4<br>B4<br>C4<br>D4<br>E4<br>F4<br>9EE4<br>9ED4 | ii<br>dd<br>hh II<br>ee ff<br>ff<br>ff<br>ee ff | 23443245                        |
| ASL opr<br>ASLA<br>ASLX<br>ASL opr,X<br>ASL ,X<br>ASL opr,SP                                   | Arithmetic Shift Left<br>(Same as LSL)               | © <b>←</b> 0 b7 b0                                       | ‡ | _          | _             | ţ        | <b>‡</b> | ‡         | DIR<br>INH<br>INH<br>IX1<br>IX<br>SP1                                                        | 38<br>48<br>58<br>68<br>78<br>9E68               | dd<br>ff<br>ff                                  | 4<br>1<br>1<br>4<br>3<br>5      |
| ASR opr<br>ASRA<br>ASRX<br>ASR opr,X<br>ASR opr,X<br>ASR opr,SP                                | Arithmetic Shift Right                               | b7 b0                                                    | ‡ | _          | _             | ‡        | ‡        | 1         | DIR<br>INH<br>INH<br>IX1<br>IX<br>SP1                                                        | 37<br>47<br>57<br>67<br>77<br>9E67               | dd<br>ff<br>ff                                  | 4<br>1<br>1<br>4<br>3<br>5      |
| BCC rel                                                                                        | Branch if Carry Bit Clear                            | $PC \leftarrow (PC) + 2 + rel ? (C) = 0$                 | - | _          | -             | _        | _        | _         | REL                                                                                          | 24                                               | rr                                              | 3                               |
| BCLR n, opr                                                                                    | Clear Bit n in M                                     | Mn ← 0                                                   | _ | _          | _             | _        | _        | _         | DIR (b0)<br>DIR (b1)<br>DIR (b2)<br>DIR (b3)<br>DIR (b4)<br>DIR (b5)<br>DIR (b6)<br>DIR (b7) | 11<br>13<br>15<br>17<br>19<br>1B<br>1D<br>1F     | dd<br>dd<br>dd<br>dd<br>dd<br>dd<br>dd<br>dd    | 4<br>4<br>4<br>4<br>4<br>4<br>4 |
| BCS rel                                                                                        | Branch if Carry Bit Set (Same as BLO)                | PC ← (PC) + 2 + rel? (C) = 1                             | - | -          | _             | _        | _        | _         | REL                                                                                          | 25                                               | rr                                              | 3                               |
| BEQ rel                                                                                        | Branch if Equal                                      | $PC \leftarrow (PC) + 2 + rel? (Z) = 1$                  | _ | [-         | _             | _        | _        | _         | REL                                                                                          | 27                                               | rr                                              | 3                               |
| BGE opr                                                                                        | Branch if Greater Than or Equal To (Signed Operands) | $PC \leftarrow (PC) + 2 + rel? (N \oplus V) = 0$         | _ | -          | _             | _        | -        | _         | REL                                                                                          | 90                                               | rr                                              | 3                               |
| BGT opr                                                                                        | Branch if Greater Than (Signed Operands)             | $PC \leftarrow (PC) + 2 + rel?(Z) \mid (N \oplus V) = 0$ | _ | -          | _             | _        | _        | _         | REL                                                                                          | 92                                               | rr                                              | 3                               |
| BHCC rel                                                                                       | Branch if Half Carry Bit Clear                       | $PC \leftarrow (PC) + 2 + rel? (H) = 0$                  | _ | <u> </u> - | _             | _        | _        | _         | REL                                                                                          | 28                                               | rr                                              | 3                               |
| BHCS rel                                                                                       | Branch if Half Carry Bit Set                         | PC ← (PC) + 2 + rel? (H) = 1                             | _ | -          | _             | _        | _        | <u> -</u> | REL                                                                                          | 29                                               | rr                                              | 3                               |
| BHI rel                                                                                        | Branch if Higher                                     | $PC \leftarrow (PC) + 2 + rel? (C)   (Z) = 0$            | - | -          | -             | -        | -        | _         | REL                                                                                          | 22                                               | rr                                              | 3                               |

Table 7-1. Instruction Set Summary (Sheet 2 of 6)

| Source                                                                                                | Operation                                         | Description                                                                                                                                                                                                                                                                                                                                   |               |          | Effect<br>on CCR |   |   |    | Address<br>Mode                                                                              | Opcode                                       | Operand                                                              | es                                    |
|-------------------------------------------------------------------------------------------------------|---------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------|----------|------------------|---|---|----|----------------------------------------------------------------------------------------------|----------------------------------------------|----------------------------------------------------------------------|---------------------------------------|
| Form                                                                                                  |                                                   | 233311                                                                                                                                                                                                                                                                                                                                        | ٧             | Н        | ı                | Ν | Z | С  | Add                                                                                          | odo                                          | Ope                                                                  | Cycles                                |
| BHS rel                                                                                               | Branch if Higher or Same<br>(Same as BCC)         | PC ← (PC) + 2 + rel? (C) = 0                                                                                                                                                                                                                                                                                                                  | _             | -        | _                | - | - | -  | REL                                                                                          | 24                                           | rr                                                                   | 3                                     |
| BIH rel                                                                                               | Branch if IRQ Pin High                            | PC ← (PC) + 2 + <i>rel</i> ? IRQ = 1                                                                                                                                                                                                                                                                                                          | -             | -        | -                | - | - | -  | REL                                                                                          | 2F                                           | rr                                                                   | 3                                     |
| BIL rel                                                                                               | Branch if IRQ Pin Low                             | $PC \leftarrow (PC) + 2 + rel ? \overline{IRQ} = 0$                                                                                                                                                                                                                                                                                           | -             | <u> </u> | -                | _ | - | _  | REL                                                                                          | 2E                                           | rr                                                                   | 3                                     |
| BIT #opr<br>BIT opr<br>BIT opr<br>BIT opr,X<br>BIT opr,X<br>BIT,X<br>BIT opr,SP<br>BIT opr,SP         | Bit Test                                          | (A) & (M)                                                                                                                                                                                                                                                                                                                                     | 0             | _        | _                | ‡ | ‡ | ı  | IMM<br>DIR<br>EXT<br>IX2<br>IX1<br>IX<br>SP1<br>SP2                                          | A5<br>B5<br>C5<br>D5<br>E5<br>F5<br>9ED5     |                                                                      | 2<br>3<br>4<br>4<br>3<br>2<br>4<br>5  |
| BLE opr                                                                                               | Branch if Less Than or Equal To (Signed Operands) | $PC \leftarrow (PC) + 2 + rel ? (Z)   (N \oplus V) = 1$                                                                                                                                                                                                                                                                                       | _             | -        | _                | - | - | -  | REL                                                                                          | 93                                           | rr                                                                   | 3                                     |
| BLO rel                                                                                               | Branch if Lower (Same as BCS)                     | $PC \leftarrow (PC) + 2 + rel? (C) = 1$                                                                                                                                                                                                                                                                                                       | _             | _        | _                | _ | _ | -  | REL                                                                                          | 25                                           | rr                                                                   | 3                                     |
| BLS rel                                                                                               | Branch if Lower or Same                           | $PC \leftarrow (PC) + 2 + rel? (C)   (Z) = 1$                                                                                                                                                                                                                                                                                                 | _             | Ŀ        | _                | _ | - | _  | REL                                                                                          | 23                                           | rr                                                                   | 3                                     |
| BLT opr                                                                                               | Branch if Less Than (Signed Operands)             | $PC \leftarrow (PC) + 2 + rel? (N \oplus V) = 1$                                                                                                                                                                                                                                                                                              | -             | -        | -                | _ | - | -  | REL                                                                                          | 91                                           | rr                                                                   | 3                                     |
| BMC rel                                                                                               | Branch if Interrupt Mask Clear                    | $PC \leftarrow (PC) + 2 + rel? (I) = 0$                                                                                                                                                                                                                                                                                                       | -             | -        | -                | _ | _ | -  | REL                                                                                          | 2C                                           | rr                                                                   | 3                                     |
| BMI rel                                                                                               | Branch if Minus                                   | $PC \leftarrow (PC) + 2 + rel? (N) = 1$                                                                                                                                                                                                                                                                                                       | _             | -        | _                | _ | _ | -  | REL                                                                                          | 2B                                           | rr                                                                   | 3                                     |
| BMS rel                                                                                               | Branch if Interrupt Mask Set                      | PC ← (PC) + 2 + rel? (I) = 1                                                                                                                                                                                                                                                                                                                  | _             | -        | -                | _ | _ | -  | REL                                                                                          | 2D                                           | rr                                                                   | 3                                     |
| BNE rel                                                                                               | Branch if Not Equal                               | $PC \leftarrow (PC) + 2 + rel? (Z) = 0$                                                                                                                                                                                                                                                                                                       | _             | -        | -                | _ | _ | -  | REL                                                                                          | 26                                           | rr                                                                   | 3                                     |
| BPL rel                                                                                               | Branch if Plus                                    | $PC \leftarrow (PC) + 2 + rel? (N) = 0$                                                                                                                                                                                                                                                                                                       | _             | -        | -                | _ | _ | -  | REL                                                                                          | 2A                                           | rr                                                                   | 3                                     |
| BRA rel                                                                                               | Branch Always                                     | PC ← (PC) + 2 + <i>rel</i>                                                                                                                                                                                                                                                                                                                    | _             | -        | -                | _ | _ | -  | REL                                                                                          | 20                                           | rr                                                                   | 3                                     |
| BRCLR n,opr,rel                                                                                       | Branch if Bit <i>n</i> in M Clear                 | PC ← (PC) + 3 + <i>rel</i> ? (Mn) = 0                                                                                                                                                                                                                                                                                                         | _             | _        | _                | 1 | ľ | ţ  | DIR (b0)<br>DIR (b1)<br>DIR (b2)<br>DIR (b3)<br>DIR (b4)<br>DIR (b5)<br>DIR (b6)<br>DIR (b7) | 01<br>03<br>05<br>07<br>09<br>0B<br>0D<br>0F | dd rr<br>dd rr<br>dd rr<br>dd rr<br>dd rr<br>dd rr<br>dd rr<br>dd rr | 5555555                               |
| BRN rel                                                                                               | Branch Never                                      | PC ← (PC) + 2                                                                                                                                                                                                                                                                                                                                 | -             | -        | -                | - | - | -  | REL                                                                                          | 21                                           | rr                                                                   | 3                                     |
| BRSET n,opr,rel                                                                                       | Branch if Bit <i>n</i> in M Set                   | PC ← (PC) + 3 + <i>rel</i> ? (Mn) = 1                                                                                                                                                                                                                                                                                                         | _             | _        | _                | ı | ı | Į. | DIR (b0)<br>DIR (b1)<br>DIR (b2)<br>DIR (b3)<br>DIR (b4)<br>DIR (b5)<br>DIR (b6)<br>DIR (b7) | 00<br>02<br>04<br>06<br>08<br>0A<br>0C<br>0E | dd rr<br>dd rr<br>dd rr<br>dd rr<br>dd rr<br>dd rr<br>dd rr<br>dd rr | 5 5 5 5 5 5 5 5 5 5 5 5 5 5 5 5 5 5 5 |
| BSET n,opr                                                                                            | Set Bit n in M                                    | Mn ← 1                                                                                                                                                                                                                                                                                                                                        | _             | _        | _                | - | _ | _  | DIR (b0)<br>DIR (b1)<br>DIR (b2)<br>DIR (b3)<br>DIR (b4)<br>DIR (b5)<br>DIR (b6)<br>DIR (b7) | 10<br>12<br>14<br>16<br>18<br>1A<br>1C<br>1E | dd<br>dd<br>dd<br>dd<br>dd<br>dd<br>dd<br>dd                         | 4<br>4<br>4<br>4<br>4<br>4<br>4       |
| BSR rel                                                                                               | Branch to Subroutine                              | $ \begin{array}{c} PC \leftarrow (PC) + 2;  push  (PCL) \\ SP \leftarrow (SP) - 1;  push  (PCH) \\ SP \leftarrow (SP) - 1 \\ PC \leftarrow (PC) + \mathit{rel} \end{array} $                                                                                                                                                                  | _             | _        | _                | _ | _ | -  | REL                                                                                          | AD                                           | rr                                                                   | 4                                     |
| CBEQ opr,rel<br>CBEQA #opr,rel<br>CBEQX #opr,rel<br>CBEQ opr,X+,rel<br>CBEQ X+,rel<br>CBEQ opr,SP,rel | Compare and Branch if Equal                       | $\begin{array}{l} PC \leftarrow (PC) + 3 + rel~?~(A) - (M) = \$00 \\ PC \leftarrow (PC) + 3 + rel~?~(A) - (M) = \$00 \\ PC \leftarrow (PC) + 3 + rel~?~(X) - (M) = \$00 \\ PC \leftarrow (PC) + 3 + rel~?~(A) - (M) = \$00 \\ PC \leftarrow (PC) + 2 + rel~?~(A) - (M) = \$00 \\ PC \leftarrow (PC) + 4 + rel~?~(A) - (M) = \$00 \end{array}$ | _             | _        | _                | ı | - | _  | DIR<br>IMM<br>IMM<br>IX1+<br>IX+<br>SP1                                                      | 31<br>41<br>51<br>61<br>71<br>9E61           | dd rr<br>ii rr<br>ii rr<br>ff rr<br>ff rr<br>ff rr                   | 5<br>4<br>4<br>5<br>4<br>6            |
|                                                                                                       |                                                   |                                                                                                                                                                                                                                                                                                                                               | $\overline{}$ |          | _                | - | _ | _  |                                                                                              |                                              |                                                                      |                                       |
| CLC                                                                                                   | Clear Carry Bit                                   | C ← 0                                                                                                                                                                                                                                                                                                                                         | -             | -        | -                | - | _ | 0  | INH                                                                                          | 98                                           |                                                                      | 1                                     |

## Central Processor Unit (CPU)

Table 7-1. Instruction Set Summary (Sheet 3 of 6)

| Source                                                                                         | Operation Description            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |   |   | ec |          |          | Address<br>Mode | Opcode                                              | Operand                                          | les                                             |                                      |
|------------------------------------------------------------------------------------------------|----------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|---|----|----------|----------|-----------------|-----------------------------------------------------|--------------------------------------------------|-------------------------------------------------|--------------------------------------|
| Form                                                                                           | орогинон                         | 2000                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | ٧ | Н | I  | N        | Z        | С               | Add                                                 | Opc                                              | Ope                                             | Cycles                               |
| CLR opr<br>CLRA<br>CLRX<br>CLRH<br>CLR opr,X<br>CLR ,X<br>CLR opr,SP                           | Clear                            | $\begin{array}{c} M \leftarrow \$00 \\ A \leftarrow \$00 \\ X \leftarrow \$00 \\ X \leftarrow \$00 \\ H \leftarrow \$00 \\ M \leftarrow \$00 \\ M \leftarrow \$00 \\ M \leftarrow \$00 \\ \end{array}$                                                                                                                                                                                                                                                                                                                                                                                                                          | 0 | _ | _  | 0        | 1        | _               | DIR<br>INH<br>INH<br>INH<br>IX1<br>IX<br>SP1        | 3F<br>4F<br>5F<br>8C<br>6F<br>7F<br>9E6F         | dd<br>ff                                        | 3<br>1<br>1<br>3<br>2<br>4           |
| CMP #opr<br>CMP opr<br>CMP opr,<br>CMP opr,X<br>CMP opr,X<br>CMP,X<br>CMP opr,SP<br>CMP opr,SP | Compare A with M                 | (A) – (M)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 1 | _ | _  | <b>‡</b> | 1        | ‡               | IMM<br>DIR<br>EXT<br>IX2<br>IX1<br>IX<br>SP1<br>SP2 | A1<br>B1<br>C1<br>D1<br>E1<br>F1<br>9EE1<br>9ED1 | ii<br>dd<br>hh II<br>ee ff<br>ff<br>ff<br>ee ff | 2<br>3<br>4<br>4<br>3<br>2<br>4<br>5 |
| COM opr<br>COMA<br>COMX<br>COM opr,X<br>COM ,X<br>COM opr,SP                                   | Complement (One's Complement)    | $\begin{array}{l} M \leftarrow (\overline{M}) = \$FF - (M) \\ A \leftarrow (A) = \$FF - (M) \\ X \leftarrow (\overline{X}) = \$FF - (M) \\ M \leftarrow (\overline{M}) = \$FF - (M) \end{array}$                                                                                                                                                                                                                                                                                            | 0 | _ | _  | <b>‡</b> | ‡        | 1               | DIR<br>INH<br>INH<br>IX1<br>IX<br>SP1               | 33<br>43<br>53<br>63<br>73<br>9E63               | dd<br>ff<br>ff                                  | 4<br>1<br>1<br>4<br>3<br>5           |
| CPHX #opr<br>CPHX opr                                                                          | Compare H:X with M               | (H:X) – (M:M + 1)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | 1 | - | -  | 1        | ‡        | 1               | IMM<br>DIR                                          | 65<br>75                                         | ii ii+1<br>dd                                   | 3                                    |
| CPX #opr<br>CPX opr<br>CPX opr<br>CPX,X<br>CPX opr,X<br>CPX opr,X<br>CPX opr,SP<br>CPX opr,SP  | Compare X with M                 | (X) – (M)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | ‡ | _ | _  | 1        | <b>‡</b> | <b>‡</b>        | IMM<br>DIR<br>EXT<br>IX2<br>IX1<br>IX<br>SP1<br>SP2 | A3<br>B3<br>C3<br>D3<br>E3<br>F3<br>9EE3<br>9ED3 |                                                 | 2 3 4 4 3 2 4 5                      |
| DAA                                                                                            | Decimal Adjust A                 | (A) <sub>10</sub>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | U | - | -  | 1        | 1        | 1               | INH                                                 | 72                                               |                                                 | 2                                    |
| DBNZ opr,rel DBNZA rel DBNZX rel DBNZ opr,X,rel DBNZ X,rel DBNZ opr,SP,rel                     | Decrement and Branch if Not Zero | $\begin{array}{l} A \leftarrow (A)-1 \text{ or } M \leftarrow (M)-1 \text{ or } X \leftarrow (X)-1 \\ PC \leftarrow (PC)+3+\mathit{rel}? \text{ (result)} \neq 0 \\ PC \leftarrow (PC)+2+\mathit{rel}? \text{ (result)} \neq 0 \\ PC \leftarrow (PC)+2+\mathit{rel}? \text{ (result)} \neq 0 \\ PC \leftarrow (PC)+3+\mathit{rel}? \text{ (result)} \neq 0 \\ PC \leftarrow (PC)+3+\mathit{rel}? \text{ (result)} \neq 0 \\ PC \leftarrow (PC)+2+\mathit{rel}? \text{ (result)} \neq 0 \\ PC \leftarrow (PC)+4+\mathit{rel}? \text{ (result)} \neq 0 \\ PC \leftarrow (PC)+4+\mathit{rel}? \text{ (result)} \neq 0 \end{array}$ | _ | _ | _  | _        | _        | _               | DIR<br>INH<br>INH<br>IX1<br>IX<br>SP1               | 3B<br>4B<br>5B<br>6B<br>7B<br>9E6B               | dd rr<br>rr<br>rr<br>ff rr<br>rr<br>ff rr       | 5 3 3 5 4 6                          |
| DEC opr<br>DECA<br>DECX<br>DEC opr,X<br>DEC ,X<br>DEC opr,SP                                   | Decrement                        | $\begin{array}{c} M \leftarrow (M) - 1 \\ A \leftarrow (A) - 1 \\ X \leftarrow (X) - 1 \\ M \leftarrow (M) - 1 \\ M \leftarrow (M) - 1 \\ M \leftarrow (M) - 1 \end{array}$                                                                                                                                                                                                                                                                                                                                                                                                                                                     | ‡ | _ | _  | ţ        | ‡        | _               | DIR<br>INH<br>INH<br>IX1<br>IX<br>SP1               | 3A<br>4A<br>5A<br>6A<br>7A<br>9E6A               | dd<br>ff<br>ff                                  | 4<br>1<br>1<br>4<br>3<br>5           |
| DIV                                                                                            | Divide                           | $A \leftarrow (H:A)/(X)$<br>$H \leftarrow Remainder$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | - | - | -  | -        | ‡        | 1               | INH                                                 | 52                                               |                                                 | 7                                    |
| EOR #opr<br>EOR opr<br>EOR opr,<br>EOR opr,X<br>EOR opr,X<br>EOR,X<br>EOR opr,SP<br>EOR opr,SP | Exclusive OR M with A            | $A \leftarrow (A \oplus M)$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | 0 | _ | _  | ‡        | ‡        | _               | IMM<br>DIR<br>EXT<br>IX2<br>IX1<br>IX<br>SP1<br>SP2 | A8<br>B8<br>C8<br>D8<br>E8<br>F8<br>9EE8<br>9ED8 |                                                 | 2<br>3<br>4<br>4<br>3<br>2<br>4<br>5 |
| INC opr<br>INCA<br>INCX<br>INC opr,X<br>INC ,X<br>INC opr,SP                                   | Increment                        | $\begin{array}{c} M \leftarrow (M) + 1 \\ A \leftarrow (A) + 1 \\ X \leftarrow (X) + 1 \\ M \leftarrow (M) + 1 \\ M \leftarrow (M) + 1 \\ M \leftarrow (M) + 1 \end{array}$                                                                                                                                                                                                                                                                                                                                                                                                                                                     | 1 | _ | _  | ‡        | ‡        | _               | DIR<br>INH<br>INH<br>IX1<br>IX<br>SP1               | 3C<br>4C<br>5C<br>6C<br>7C<br>9E6C               | dd<br>ff<br>ff                                  | 4<br>1<br>1<br>4<br>3<br>5           |

Table 7-1. Instruction Set Summary (Sheet 4 of 6)

| Source                                                                                         | Operation                           | Description                                                                                                                                                                                           |           |   |   | ec<br>CC |          |          | Address<br>Mode                                     | Opcode                                           | Operand                    | les                        |
|------------------------------------------------------------------------------------------------|-------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------|---|---|----------|----------|----------|-----------------------------------------------------|--------------------------------------------------|----------------------------|----------------------------|
| Form                                                                                           | operanen                            | 2000                                                                                                                                                                                                  | ٧         | Н | I | N        | Z        | С        | Add                                                 | Opc                                              | Ope                        | Cycles                     |
| JMP opr<br>JMP opr<br>JMP opr,X<br>JMP opr,X<br>JMP ,X                                         | Jump                                | PC ← Jump Address                                                                                                                                                                                     | -         | _ | _ | _        | _        | _        | DIR<br>EXT<br>IX2<br>IX1<br>IX                      | BC<br>CC<br>DC<br>EC<br>FC                       | dd<br>hh II<br>ee ff<br>ff | 2 3 4 3 2                  |
| JSR opr<br>JSR opr,<br>JSR opr,X<br>JSR opr,X<br>JSR ,X                                        | Jump to Subroutine                  | $PC \leftarrow (PC) + n (n = 1, 2, \text{ or } 3)$<br>$Push (PCL); SP \leftarrow (SP) - 1$<br>$Push (PCH); SP \leftarrow (SP) - 1$<br>$PC \leftarrow Unconditional Address$                           | _         | _ | _ | _        | _        | _        | DIR<br>EXT<br>IX2<br>IX1<br>IX                      | BD<br>CD<br>DD<br>ED<br>FD                       | dd<br>hh II<br>ee ff<br>ff | 4<br>5<br>6<br>5<br>4      |
| LDA #opr<br>LDA opr<br>LDA opr<br>LDA opr,X<br>LDA opr,X<br>LDA, X<br>LDA opr,SP<br>LDA opr,SP | Load A from M                       | $A \leftarrow (M)$                                                                                                                                                                                    | 0         | _ | _ | ţ        | ‡        | _        | IMM<br>DIR<br>EXT<br>IX2<br>IX1<br>IX<br>SP1<br>SP2 | A6<br>B6<br>C6<br>D6<br>E6<br>F6<br>9EE6<br>9ED6 |                            | 2 3 4 4 3 2 4 5            |
| LDHX #opr<br>LDHX opr                                                                          | Load H:X from M                     | $H:X \leftarrow (M:M+1)$                                                                                                                                                                              | 0         | - | - | 1        | 1        | _        | IMM<br>DIR                                          | 45<br>55                                         | ii jj<br>dd                | 3 4                        |
| LDX #opr<br>LDX opr<br>LDX opr<br>LDX opr,X<br>LDX opr,X<br>LDX,X<br>LDX opr,SP<br>LDX opr,SP  | Load X from M                       | X ← (M)                                                                                                                                                                                               | 0         | _ | _ | 1        | ‡        | _        | IMM DIR EXT IX2 IX1 IX SP1 SP2                      | AE<br>BE<br>CE<br>DE<br>EE<br>FE<br>9EEE<br>9EDE |                            | 2 3 4 4 3 2 4 5            |
| LSL opr<br>LSLA<br>LSLX<br>LSL opr,X<br>LSL ,X<br>LSL opr,SP                                   | Logical Shift Left<br>(Same as ASL) | □                                                                                                                                                                                                     | 1         | _ | _ | 1        | ‡        | <b>‡</b> | DIR<br>INH<br>INH<br>IX1<br>IX<br>SP1               | 38<br>48<br>58<br>68<br>78<br>9E68               | dd<br>ff<br>ff             | 4<br>1<br>1<br>4<br>3<br>5 |
| LSR opr<br>LSRA<br>LSRX<br>LSR opr,X<br>LSR ,X<br>LSR opr,SP                                   | Logical Shift Right                 | 0 - C b7 b0                                                                                                                                                                                           | ‡         | _ | _ | 0        | <b>‡</b> | 1        | DIR<br>INH<br>INH<br>IX1<br>IX<br>SP1               | 34<br>44<br>54<br>64<br>74<br>9E64               | dd<br>ff<br>ff             | 4<br>1<br>1<br>4<br>3<br>5 |
| MOV opr,opr<br>MOV opr,X+<br>MOV #opr,opr<br>MOV X+,opr                                        | Move                                | $(M)_{Destination} \leftarrow (M)_{Source}$ $H:X \leftarrow (H:X) + 1 (IX+D, DIX+)$                                                                                                                   | 0         | _ | _ | 1        | ‡        | _        | DD<br>DIX+<br>IMD<br>IX+D                           | 4E<br>5E<br>6E<br>7E                             | dd dd<br>dd<br>ii dd<br>dd | 5<br>4<br>4<br>4           |
| MUL                                                                                            | Unsigned multiply                   | $X:A \leftarrow (X) \times (A)$                                                                                                                                                                       | _         | 0 | _ | _        | -        | 0        | INH                                                 | 42                                               |                            | 5                          |
| NEG opr<br>NEGA<br>NEGX<br>NEG opr,X<br>NEG ,X<br>NEG opr,SP                                   | Negate (Two's Complement)           | $\begin{array}{l} M \leftarrow -(M) = \$00 - (M) \\ A \leftarrow -(A) = \$00 - (A) \\ X \leftarrow -(X) = \$00 - (X) \\ M \leftarrow -(M) = \$00 - (M) \\ M \leftarrow -(M) = \$00 - (M) \end{array}$ | 1         | _ | _ | 1        | 1        | ‡        | DIR<br>INH<br>INH<br>IX1<br>IX<br>SP1               | 30<br>40<br>50<br>60<br>70<br>9E60               | dd<br>ff<br>ff             | 4<br>1<br>1<br>4<br>3<br>5 |
| NOP                                                                                            | No Operation                        | None                                                                                                                                                                                                  | _         | _ | _ | _        | _        | _        | INH                                                 | 9D                                               |                            | 1                          |
| NSA                                                                                            | Nibble Swap A                       | A ← (A[3:0]:A[7:4])                                                                                                                                                                                   | 1-        | _ | _ | -        | _        | _        | INH                                                 | 62                                               |                            | 3                          |
| ORA #opr<br>ORA opr<br>ORA opr,<br>ORA opr,X<br>ORA opr,X<br>ORA,X<br>ORA opr,SP<br>ORA opr,SP | Inclusive OR A and M                | A ← (A)   (M)                                                                                                                                                                                         | 0         | _ | _ | 1        | ‡        | _        | IMM<br>DIR<br>EXT<br>IX2<br>IX1<br>IX<br>SP1<br>SP2 | AA<br>BA<br>CA<br>DA<br>EA<br>FA<br>9EEA<br>9EDA |                            | 23443245                   |
| PSHA                                                                                           | Push A onto Stack                   | Push (A); SP ← (SP) – 1                                                                                                                                                                               | <u> </u>  | _ | _ | _        | _        | _        | INH                                                 | 87                                               |                            | 2                          |
| PSHH                                                                                           | Push H onto Stack                   | Push (H); SP ← (SP) – 1                                                                                                                                                                               | <u> -</u> | _ | _ | _        | _        | _        | INH                                                 | 8B                                               |                            | 2                          |
| PSHX                                                                                           | Push X onto Stack                   | Push (X); SP $\leftarrow$ (SP) – 1                                                                                                                                                                    | -         | - | - | -        | -        | _        | INH                                                 | 89                                               |                            | 2                          |

## Central Processor Unit (CPU)

Table 7-1. Instruction Set Summary (Sheet 5 of 6)

| Source                                                                                         | Operation Description                                             |                                                                                                                                                                                                                                 |   |   |   |          |   |          | Address<br>Mode                                     | Opcode                                           | Operand                                   | les                             |
|------------------------------------------------------------------------------------------------|-------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|---|---|----------|---|----------|-----------------------------------------------------|--------------------------------------------------|-------------------------------------------|---------------------------------|
| Form                                                                                           |                                                                   | <b>,</b>                                                                                                                                                                                                                        | ٧ | н | ı | N        | Z | С        | Add                                                 | Opc                                              | Ope                                       | Cycles                          |
| PULA                                                                                           | Pull A from Stack                                                 | $SP \leftarrow (SP + 1); Pull (A)$                                                                                                                                                                                              | - | - | _ | -        | - | -        | INH                                                 | 86                                               |                                           | 2                               |
| PULH                                                                                           | Pull H from Stack                                                 | SP ← (SP + 1); Pull (H)                                                                                                                                                                                                         | - | - | - | -        | - | -        | INH                                                 | 8A                                               |                                           | 2                               |
| PULX                                                                                           | Pull X from Stack                                                 | $SP \leftarrow (SP + 1); Pull(X)$                                                                                                                                                                                               | - | - | - | -        | - | -        | INH                                                 | 88                                               |                                           | 2                               |
| ROL opr<br>ROLA<br>ROLX<br>ROL opr,X<br>ROL ,X<br>ROL opr,SP                                   | Rotate Left through Carry                                         | b7 b0                                                                                                                                                                                                                           | 1 | _ | _ | <b>‡</b> | ‡ | <b>‡</b> | DIR<br>INH<br>INH<br>IX1<br>IX<br>SP1               | 39<br>49<br>59<br>69<br>79<br>9E69               | dd<br>ff<br>ff                            | 4<br>1<br>1<br>4<br>3<br>5      |
| ROR opr<br>RORA<br>RORX<br>ROR opr,X<br>ROR ,X<br>ROR opr,SP                                   | Rotate Right through Carry                                        | b7 b0                                                                                                                                                                                                                           | ‡ | _ | _ | ‡        | ‡ | ‡        | DIR<br>INH<br>INH<br>IX1<br>IX<br>SP1               | 36<br>46<br>56<br>66<br>76<br>9E66               | dd<br>ff<br>ff                            | 4<br>1<br>1<br>4<br>3<br>5      |
| RSP                                                                                            | Reset Stack Pointer                                               | SP ← \$FF                                                                                                                                                                                                                       | - | - | - | -        | - | -        | INH                                                 | 9C                                               |                                           | 1                               |
| RTI                                                                                            | Return from Interrupt                                             | $\begin{array}{l} SP \leftarrow (SP) + 1;  Pull  (CCR) \\ SP \leftarrow (SP) + 1;  Pull  (A) \\ SP \leftarrow (SP) + 1;  Pull  (X) \\ SP \leftarrow (SP) + 1;  Pull  (PCH) \\ SP \leftarrow (SP) + 1;  Pull  (PCL) \end{array}$ | 1 | ţ | ţ | ţ        | ‡ | ţ        | INH                                                 | 80                                               |                                           | 7                               |
| RTS                                                                                            | Return from Subroutine                                            | $SP \leftarrow SP + 1$ ; Pull (PCH)<br>$SP \leftarrow SP + 1$ ; Pull (PCL)                                                                                                                                                      | - | - | _ | -        | - | -        | INH                                                 | 81                                               |                                           | 4                               |
| SBC #opr<br>SBC opr<br>SBC opr<br>SBC opr,X<br>SBC opr,X<br>SBC,X<br>SBC opr,SP<br>SBC opr,SP  | Subtract with Carry                                               | $A \leftarrow (A) - (M) - (C)$                                                                                                                                                                                                  | 1 | - | _ | ‡        | ‡ | ‡        | IMM<br>DIR<br>EXT<br>IX2<br>IX1<br>IX<br>SP1<br>SP2 | A2<br>B2<br>C2<br>D2<br>E2<br>F2<br>9EE2<br>9ED2 | ii<br>dd<br>hh II<br>ee ff<br>ff<br>ff    | 23443245                        |
| SEC                                                                                            | Set Carry Bit                                                     | C ← 1                                                                                                                                                                                                                           | - | - | - | -        | - | 1        | INH                                                 | 99                                               |                                           | 1                               |
| SEI                                                                                            | Set Interrupt Mask                                                | I ← 1                                                                                                                                                                                                                           | - | - | 1 | -        | - | -        | INH                                                 | 9B                                               |                                           | 2                               |
| STA opr<br>STA opr,<br>STA opr,X<br>STA opr,X<br>STA ,X<br>STA opr,SP<br>STA opr,SP            | Store A in M                                                      | $M \leftarrow (A)$                                                                                                                                                                                                              | 0 | _ | _ | 1        | 1 | _        | DIR<br>EXT<br>IX2<br>IX1<br>IX<br>SP1<br>SP2        | B7<br>C7<br>D7<br>E7<br>F7<br>9EE7<br>9ED7       | dd<br>hh II<br>ee ff<br>ff<br>ff<br>ee ff | 3<br>4<br>4<br>3<br>2<br>4<br>5 |
| STHX opr                                                                                       | Store H:X in M                                                    | (M:M + 1) ← (H:X)                                                                                                                                                                                                               | 0 | - | _ | 1        | 1 | -        | DIR                                                 | 35                                               | dd                                        | 4                               |
| STOP                                                                                           | Enable Interrupts, Stop Processing,<br>Refer to MCU Documentation | I ← 0; Stop Processing                                                                                                                                                                                                          | - | - | 0 | -        | - | -        | INH                                                 | 8E                                               |                                           | 1                               |
| STX opr<br>STX opr<br>STX opr,X<br>STX opr,X<br>STX,X<br>STX,X<br>STX opr,SP<br>STX opr,SP     | Store X in M                                                      | $M \leftarrow (X)$                                                                                                                                                                                                              | 0 | _ | _ | 1        | ‡ | _        | DIR<br>EXT<br>IX2<br>IX1<br>IX<br>SP1<br>SP2        | BF<br>CF<br>DF<br>EF<br>FF<br>9EEF<br>9EDF       | dd<br>hh II<br>ee ff<br>ff<br>ff<br>ee ff | 3<br>4<br>4<br>3<br>2<br>4<br>5 |
| SUB #opr<br>SUB opr<br>SUB opr,<br>SUB opr,X<br>SUB opr,X<br>SUB,X<br>SUB opr,SP<br>SUB opr,SP | Subtract                                                          | $A \leftarrow (A) - (M)$                                                                                                                                                                                                        | 1 | _ | _ | 1        | 1 | 1        | IMM<br>DIR<br>EXT<br>IX2<br>IX1<br>IX<br>SP1<br>SP2 | A0<br>B0<br>C0<br>D0<br>E0<br>F0<br>9EE0<br>9ED0 |                                           | 2 3 4 4 3 2 4 5                 |

**Opcode Map** 

Table 7-1. Instruction Set Summary (Sheet 6 of 6)

| Source                                                       | Operation Description                 |                                                                                                                                                                                                                                                                                                                                                                              |   |   |   |   |   |   | ress<br>e                             | Opcode                             | Operand        | les                        |
|--------------------------------------------------------------|---------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|---|---|---|---|---|---------------------------------------|------------------------------------|----------------|----------------------------|
| Form                                                         | оролино                               | 2000ро                                                                                                                                                                                                                                                                                                                                                                       | ٧ | Н | I | N | Z | С | Addres                                | Opc                                | Ope            | Cycles                     |
| SWI                                                          | Software Interrupt                    | $\begin{array}{c} PC \leftarrow (PC) + 1;  Push  (PCL) \\ SP \leftarrow (SP) - 1;  Push  (PCH) \\ SP \leftarrow (SP) - 1;  Push  (X) \\ SP \leftarrow (SP) - 1;  Push  (A) \\ SP \leftarrow (SP) - 1;  Push  (CCR) \\ SP \leftarrow (SP) - 1;  l \leftarrow 1 \\ PCH \leftarrow Interrupt  Vector  High  Byte \\ PCL \leftarrow Interrupt  Vector  Low  Byte \\ \end{array}$ | - | _ | 1 | _ | - | _ | INH                                   | 83                                 |                | 9                          |
| TAP                                                          | Transfer A to CCR                     | CCR ← (A)                                                                                                                                                                                                                                                                                                                                                                    | 1 | 1 | 1 | 1 | 1 | 1 | INH                                   | 84                                 |                | 2                          |
| TAX                                                          | Transfer A to X                       | X ← (A)                                                                                                                                                                                                                                                                                                                                                                      | - | - | - | - | - | - | INH                                   | 97                                 |                | 1                          |
| TPA                                                          | Transfer CCR to A                     | A ← (CCR)                                                                                                                                                                                                                                                                                                                                                                    | - | - | - | - | - | - | INH                                   | 85                                 |                | 1                          |
| TST opr<br>TSTA<br>TSTX<br>TST opr,X<br>TST ,X<br>TST opr,SP | Test for Negative or Zero             | (A) – \$00 or (X) – \$00 or (M) – \$00                                                                                                                                                                                                                                                                                                                                       | 0 | _ | _ | 1 | 1 | _ | DIR<br>INH<br>INH<br>IX1<br>IX<br>SP1 | 3D<br>4D<br>5D<br>6D<br>7D<br>9E6D | dd<br>ff<br>ff | 3<br>1<br>1<br>3<br>2<br>4 |
| TSX                                                          | Transfer SP to H:X                    | H:X ← (SP) + 1                                                                                                                                                                                                                                                                                                                                                               | - | - | - | - | - | - | INH                                   | 95                                 |                | 2                          |
| TXA                                                          | Transfer X to A                       | A ← (X)                                                                                                                                                                                                                                                                                                                                                                      | - | - | - | - | - | - | INH                                   | 9F                                 |                | 1                          |
| TXS                                                          | Transfer H:X to SP                    | (SP) ← (H:X) – 1                                                                                                                                                                                                                                                                                                                                                             | _ | - | _ | - | _ | _ | INH                                   | 94                                 |                | 2                          |
| WAIT                                                         | Enable Interrupts; Wait for Interrupt | I bit ← 0; Inhibit CPU clocking until interrupted                                                                                                                                                                                                                                                                                                                            | - | - | 0 | - | - | - | INH                                   | 8F                                 |                | 1                          |

|       |                                                                     |                  | <del></del>                                 |
|-------|---------------------------------------------------------------------|------------------|---------------------------------------------|
| Α     | Accumulator                                                         | n                | Any bit                                     |
| С     | Carry/borrow bit                                                    | opr              | Operand (one or two bytes)                  |
| CCR   | Condition code register                                             | PC               | Program counter                             |
| dd    | Direct address of operand                                           | PCH              | Program counter high byte                   |
| dd rr | Direct address of operand and relative offset of branch instruction | PCL              | Program counter low byte                    |
| DD    | Direct to direct addressing mode                                    | REL              | Relative addressing mode                    |
| DIR   | Direct addressing mode                                              | rel              | Relative program counter offset byte        |
| DIX+  | Direct to indexed with post increment addressing mode               | rr               | Relative program counter offset byte        |
| ee ff | High and low bytes of offset in indexed, 16-bit offset addressing   | SP1              | Stack pointer, 8-bit offset addressing mode |
| EXT   | Extended addressing mode                                            | SP2              | Stack pointer 16-bit offset addressing mode |
| ff    | Offset byte in indexed, 8-bit offset addressing                     | SP               | Stack pointer                               |
| Н     | Half-carry bit                                                      | U                | Undefined                                   |
| Н     | Index register high byte                                            | V                | Overflow bit                                |
| hh II | High and low bytes of operand address in extended addressing        | Χ                | Index register low byte                     |
|       | Interrupt mask                                                      | Z                | Zero bit                                    |
| ii    | Immediate operand byte                                              | &                | Logical AND                                 |
| IMD   | Immediate source to direct destination addressing mode              |                  | Logical OR                                  |
| IMM   | Immediate addressing mode                                           | $\oplus$         | Logical EXCLUSIVE OR                        |
| INH   | Inherent addressing mode                                            | ()               | Contents of                                 |
| IX    | Indexed, no offset addressing mode                                  | <del>-</del> ( ) | Negation (two's complement)                 |
| IX+   | Indexed, no offset, post increment addressing mode                  | #                | Immediate value                             |
| IX+D  | Indexed with post increment to direct addressing mode               | <<               | Sign extend                                 |
| IX1   | Indexed, 8-bit offset addressing mode                               | $\leftarrow$     | Loaded with                                 |
| IX1+  | Indexed, 8-bit offset, post increment addressing mode               | ?                | If                                          |
| IX2   | Indexed, 16-bit offset addressing mode                              | :                | Concatenated with                           |
| M     | Memory location                                                     | 1                | Set or cleared                              |
| N     | Negative bit                                                        | _                | Not affected                                |

## 7.8 Opcode Map

See Table 7-2.

# **Chapter 12 Input/Output Ports (PORTS)**

## 12.1 Introduction

The MC68HC08QY1A, MC68HC08QY2A and MC68HC08QY4A have thirteen bidirectional input-output (I/O) pins and one input only pin. The MC68HC08QT1A, MC68HC08QT2A and MC68HC08QT4A has five bidirectional I/O pins and one input only pin. All I/O pins are programmable as inputs or outputs.

## 12.2 Unused Pin Termination

Input pins and I/O port pins that are not used in the application must be terminated. This prevents excess current caused by floating inputs, and enhances immunity during noise or transient events. Termination methods include:

- 1. Configuring unused pins as outputs and driving high or low;
- 2. Configuring unused pins as inputs and enabling internal pull-ups;
- 3. Configuring unused pins as inputs and using external pull-up or pull-down resistors.

Never connect unused pins directly to V<sub>DD</sub> or V<sub>SS</sub>.

Since some general-purpose I/O pins are not available on all packages, these pins must be terminated as well. Either method 1 or 2 above are appropriate.

## 12.3 Port A

Port A is an 6-bit special function port that shares its pins with the keyboard interrupt (KBI) module (see Chapter 9 Keyboard Interrupt Module (KBI), the 2-channel timer interface module (TIM) (see Chapter 14 Timer Interface Module (TIM)), the 10-bit ADC (see Chapter 3 Analog-to-Digital Converter (ADC10) Module), the external interrupt (IRQ) pin (see Chapter 8 External Interrupt (IRQ)), the reset (RST) pin enabled using a configuration register (see Chapter 5 Configuration Register (CONFIG)) and the oscillator pins (see Chapter 11 Oscillator (OSC) Module).

Each port A pin also has a software configurable pullup device if the corresponding port pin is configured as an input port.

#### NOTE

PTA2 is input only.

When the  $\overline{IRQ}$  function is enabled in the configuration register 2 (CONFIG2), bit 2 of the port A data register (PTA) will always read a logic 0. In this case, the BIH and BIL instructions can be used to read the logic level on the PTA2 pin. When the  $\overline{IRQ}$  function is disabled, these instructions will behave as if the PTA2 pin is a logic 1. However, reading bit 2 of PTA will read the actual logic level on the pin.

MC68HC908QYA/QTA Family Data Sheet, Rev. 3

Input/Output Ports (PORTS)

## 12.3.1 Port A Data Register

The port A data register (PTA) contains a data latch for each of the six port A pins.



Figure 12-1. Port A Data Register (PTA)

## PTA[5:0] — Port A Data Bits

These read/write bits are software programmable. Data direction of each port A pin is under the control of the corresponding bit in data direction register A. Reset has no effect on port A data.

## AWUL — Auto Wakeup Latch Data Bit

This is a read-only bit which has the value of the auto wakeup interrupt request latch. The wakeup request signal is generated internally (see Chapter 4 Auto Wakeup Module (AWU)). There is no PTA6 port nor any of the associated bits such as PTA6 data register, pullup enable or direction.

## 12.3.2 Data Direction Register A

Data direction register A (DDRA) determines whether each port A pin is an input or an output. Writing a 1 to a DDRA bit enables the output buffer for the corresponding port A pin; a 0 disables the output buffer.



Figure 12-2. Data Direction Register A (DDRA)

## DDRA[5:0] — Data Direction Register A Bits

These read/write bits control port A data direction. Reset clears DDRA[5:0], configuring all port A pins as inputs.

- 1 = Corresponding port A pin configured as output
- 0 = Corresponding port A pin configured as input

#### NOTE

Avoid glitches on port A pins by writing to the port A data register before changing data direction register A bits from 0 to 1.

Figure 12-3 shows the port A I/O logic.

105



Figure 12-3. Port A I/O Circuit

## **NOTE**

Figure 12-3 does not apply to PTA2

When DDRAx is a 1, reading PTA reads the PTAx data latch. When DDRAx is a 0, reading PTA reads the logic level on the PTAx pin. The data latch can always be written, regardless of the state of its data direction bit.

## 12.3.3 Port A Input Pullup Enable Register

The port A input pullup enable register (PTAPUE) contains a software configurable pullup device for each of the port A pins. Each bit is individually configurable and requires the corresponding data direction register, DDRAx, to be configured as input. Each pullup device is automatically and dynamically disabled when its corresponding DDRAx bit is configured as output.



Figure 12-4. Port A Input Pullup Enable Register (PTAPUE)

#### OSC2EN — Enable PTA4 on OSC2 Pin

This read/write bit configures the OSC2 pin function when internal oscillator or RC oscillator option is selected. This bit has no effect for the XTAL or external oscillator options.

- 1 = OSC2 pin outputs the internal or RC oscillator clock (BUSCLKX4)
- 0 = OSC2 pin configured for PTA4 I/O, having all the interrupt and pullup functions

## PTAPUE[5:0] — Port A Input Pullup Enable Bits

These read/write bits are software programmable to enable pullup devices on port A pins.

- 1 = Corresponding port A pin configured to have internal pullup if its DDRA bit is set to 0
- 0 = Pullup device is disconnected on the corresponding port A pin regardless of the state of its DDRA bit

Input/Output Ports (PORTS)

## 12.3.4 Port A Summary Table

The following table summarizes the operation of the port A pins when used as a general-purpose input/output pins.

**Table 12-1. Port A Pin Functions** 

| PTAPUE | DDRA | PTA              | I/O Pin                               | Accesses to DDRA | Access    | ses to PTA               |
|--------|------|------------------|---------------------------------------|------------------|-----------|--------------------------|
| Bit    | Bit  | Bit              | Mode                                  | Read/Write       | Read      | Write                    |
| 1      | 0    | X <sup>(1)</sup> | Input, V <sub>DD</sub> <sup>(2)</sup> | DDRA5-DDRA0      | Pin       | PTA5-PTA0 <sup>(3)</sup> |
| 0      | 0    | Х                | Input, Hi-Z <sup>(4)</sup>            | DDRA5-DDRA0      | Pin       | PTA5-PTA0 <sup>(3)</sup> |
| Х      | 1    | Х                | Output                                | DDRA5-DDRA0      | PTA5-PTA0 | PTA5-PTA0 <sup>(5)</sup> |

- 1. X = don't care
- 2. I/O pin pulled to  $V_{DD}$  by internal pullup.
- 3. Writing affects data register, but does not affect input.
- 4. Hi-Z = high impedance
- 5. Output does not apply to PTA2

## 12.4 Port B

Port B is an 8-bit special function port that shares two of its pins with the 10-bit ADC (see Chapter 3 Analog-to-Digital Converter (ADC10) Module).

Each port B pin also has a software configurable pullup device if the corresponding port pin is configured as an input port.

## 12.4.1 Port B Data Register

The port B data register (PTB) contains a data latch for each of the port B pins.



Figure 12-5. Port B Data Register (PTB)

## PTB[7:0] — Port B Data Bits

These read/write bits are software programmable. Data direction of each port B pin is under the control of the corresponding bit in data direction register B. Reset has no effect on port B data.

MC68HC908QYA/QTA Family Data Sheet, Rev. 3 106 Freescale Semiconductor